package com.foodcommunity.mapper;

import com.foodcommunity.entity.User;
import org.apache.ibatis.annotations.Mapper;
import org.apache.ibatis.annotations.Param;

import java.util.List;

@Mapper
public interface UserMapper {
    User findByUsername(String username);
    User findById(Long id);
    void insert(User user);
    int update(User user);
    
    User selectByUsernameAndPassword(@Param("username") String username, @Param("password") String password);
    
    int countByUsername(String username);
    
    /**
     * 分页查询用户列表
     * @param offset 偏移量
     * @param limit 每页大小
     * @param keyword 搜索关键词（可选）
     * @return 用户列表
     */
    List<User> findUserList(@Param("offset") int offset, @Param("limit") int limit, @Param("keyword") String keyword);
    
    /**
     * 获取符合条件的用户总数
     * @param keyword 搜索关键词（可选）
     * @return 用户总数
     */
    int countUsers(@Param("keyword") String keyword);
    
    /**
     * 根据ID删除用户
     * @param id 用户ID
     * @return 影响的行数
     */
    int deleteById(Long id);
}